<template>
    <div>
        <div class="file-item relative" :style="{ height: fileSize, width: fileSize }">
            <el-image class="image" v-if="type === 'image'" fit="contain" :src="uri"></el-image>
            
            <video  class="video" v-else-if="type === 'video'" :src="uri"></video>
            <div
                v-if="type === 'video'"
                class="absolute left-1/2 top-1/2 translate-x-[-50%] translate-y-[-50%] rounded-full w-5 h-5 flex justify-center items-center bg-[rgba(0,0,0,0.3)]"
            >
                <icon name="el-icon-CaretRight" :size="18" color="#fff"/>
            </div>
            
            
            <slot></slot>
        </div>
    </div>
</template>

<script lang="ts" setup>
import Icon from "@/components/icon/index.vue";


interface FileItemInterface {
    uri: string
    // 文件类型
    type?: string
    // 图片尺寸
    fileSize?: string
}

const props = withDefaults(defineProps<FileItemInterface>(), {
    uri: '',
    type: 'image',
    fileSize: '100px'
    
})


const emits = defineEmits(['close'])


</script>

<style scoped lang="scss">
.file-item {
    box-sizing: border-box;
    position: relative;
    border-radius: 4px;
    overflow: hidden;
    @apply bg-br-extra-light border border-br-extra-light;
    .image,
    .video {
        display: block;
        box-sizing: border-box;
        width: 100%;
        height: 100%;
    }
}
</style>
